/*
 1.用户上划页面 滚动条触底 开始加载下一页数据
    1.找到滚定条触底事件 
    2。判断还有没有下一页数据
     1.获取数据的总页数 Math.ceil(总条数/页容量)
     2.获取当前的页码 pagenum
     3.判断下一页 当前的页码是否大于等于 总页数
       表示没有下一页数据
    3. 假如没有下一页数据 弹出一个提示
    4.假如还有下一页数据 来加载下一项数据
      1.当前的页码++
      2.重新发送请求
      3.数据请求回来 要对data中的数组 进行拼接 而不是全部替换！！！！！ 
*/

/*
2 .下拉刷新 
  1.触发下拉刷新事件 需要在页面的json文件中开启一个配置项 "enablePullDownRefresh":true "backgroundTextStyle":"dark"
    找到 触发下拉刷新页面
  2. 重置 数据 数组
  3. 重置页码 设置为1
  4.重新发送请求
  5.数据请求回来， 需要手动关闭 等待效果
*/
import { request } from "../../request/index.js";
import regeneratorRuntime from '../../lib/runtime/runtime';
Page({

  data: {
    tabs:[
      {
        id:0,
        value:"综合",
        isActive:true
      },
      {
        id:1,
        value:"销量",
        isActive:false
      },
      {
        id:2,
        value:"价格",
        isActive:false
      },
    ],
    goodsList:[]
  },
  //接口要的参数
  QueryParams:{
    query:"",
    cid:"",
    pagenum:1,
    pagesize:10
  },
  //总页数
  totalPages:1,
  onLoad: function (options) {
    this.QueryParams.cid=options.cid;
    this.getGoodsList()
  },
  //获取商品列表数据
  async getGoodsList(){
    const res =await request({url:"/goods/search",data:this.QueryParams});
     
    // 获取总条数
    const total =res.total;
    //计算总页数
    this.totalPages=Math.ceil(total/this.QueryParams.pagesize);
    this.setData({
      // goodsList: res.data.message.goods
      //数组
      goodsList:[...this.data.goodsList,...res.data.message.goods]
    })
    //关闭下拉 刷新的窗口  如果没有调用下拉刷新窗口 直接关闭也不会报错
    wx.stopPullDownRefresh();  
  },
  //标题的点击事件  从子组件传递过来的
  handleTabsItemChange(e){
    // console.log(e);
    //获取被点击的标题索引
    const {index}=e.detail;
    //修改原数组
    let {tabs} =this.data;
    tabs.forEach((v,i)=>i===index?v.isActive=true:v.isActive=false);
    //赋值到data中去
    this.setData({
      tabs
    });
  },
  //页面上划 滚动条触底事件
  onReachBottom(){
    //1.判断还有没有下一页数据
    if(this.QueryParams.pagenum>=this.totalPages){
      //没有下一页数据
      wx.showToast({title: '没有下一页数据了',});
        
    }else{
    //有下一页数据
    this.QueryParams.pagenum++;
    this.getGoodsList();
     }
  },
  //下拉刷新页面
  onPullDownRefresh(){
    // 1.重置数组
    this.setData({
      goodsList:[]
    })
    //重置页码
    this.QueryParams.pagenum=1;
    //重新发送请求
    this.getGoodsList();
  }

})